Includes and Included by are omitted for modules with errors
ni
My low-level reader of source code reported a mistake - "this Inform 6 directive is not supported in kits or '(-' inclusions: 'Replace AssertMapConnection;'". Low-level material written in Inform 6 syntax occurs either in kits or in matter written inside 'Include (- ... -)' in source text, either in the main source or in an extension used by it.
My low-level reader of source code reported a mistake - "this Inform 6 directive is not supported in kits or '(-' inclusions: 'Replace RemoveFromPlay;'". Low-level material written in Inform 6 syntax occurs either in kits or in matter written inside 'Include (- ... -)' in source text, either in the main source or in an extension used by it.
My low-level reader of source code reported a mistake - "this Inform 6 directive is not supported in kits or '(-' inclusions: 'Replace MoveFloatingObjects;'". Low-level material written in Inform 6 syntax occurs either in kits or in matter written inside 'Include (- ... -)' in source text, either in the main source or in an extension used by it.
Something went wrong late in compilation, when working through the 'pipeline' of code-generation steps. (This should not normally happen unless your source text is making use of '(-' and '-)' and getting that wrong, or unless you are experimenting with non-standard pipelines.) The pipeline looks like so: 1. read 2. parse-insertions 3. resolve-conditional-compilation 4. compile-splats 5. load-binary-kits Problem: found a second definition of the name 'RemoveFromPlay' when loading '/main/WorldModelKit' 6. make-synoptic-module 7. shorten-wiring 8. detect-indirect-calls 9. make-identifiers-unique 10. reconcile-verbs 11. eliminate-redundant-labels 12. eliminate-redundant-operations 13. optionally-generate text -> 14. generate 15. index
Something went wrong late in compilation, when working through the 'pipeline' of code-generation steps. (This should not normally happen unless your source text is making use of '(-' and '-)' and getting that wrong, or unless you are experimenting with non-standard pipelines.) The pipeline looks like so: 1. read 2. parse-insertions 3. resolve-conditional-compilation 4. compile-splats 5. load-binary-kits Problem: found a second definition of the name 'MoveFloatingObjects' when loading '/main/WorldModelKit' 6. make-synoptic-module 7. shorten-wiring 8. detect-indirect-calls 9. make-identifiers-unique 10. reconcile-verbs 11. eliminate-redundant-labels 12. eliminate-redundant-operations 13. optionally-generate text -> 14. generate 15. index
Something went wrong late in compilation, when working through the 'pipeline' of code-generation steps. (This should not normally happen unless your source text is making use of '(-' and '-)' and getting that wrong, or unless you are experimenting with non-standard pipelines.) The pipeline looks like so: 1. read 2. parse-insertions 3. resolve-conditional-compilation 4. compile-splats 5. load-binary-kits Problem: found a second definition of the name 'AssertMapConnection' when loading '/main/WorldModelKit' 6. make-synoptic-module 7. shorten-wiring 8. detect-indirect-calls 9. make-identifiers-unique 10. reconcile-verbs 11. eliminate-redundant-labels 12. eliminate-redundant-operations 13. optionally-generate text -> 14. generate 15. index
Something went wrong late in compilation, when working through the 'pipeline' of code-generation steps. (This should not normally happen unless your source text is making use of '(-' and '-)' and getting that wrong, or unless you are experimenting with non-standard pipelines.) The pipeline looks like so: 1. read 2. parse-insertions 3. resolve-conditional-compilation 4. compile-splats 5. load-binary-kits 6. make-synoptic-module 7. shorten-wiring Problem: unable to find definitions for the following name(s): mobile, mobile_door, mobile_door_dir, mobile_door_to 8. detect-indirect-calls 9. make-identifiers-unique 10. reconcile-verbs 11. eliminate-redundant-labels 12. eliminate-redundant-operations 13. optionally-generate text -> 14. generate 15. index
Include Mobile Doors by David Corbett.
Inform 7 allows the connections between rooms to be modified during play, but doors never change. This extension makes doors as versatile as rooms. Section: Basic moving A door connects at most two rooms. A room may have an associated direction; if it does not, the door is one-sided and does not appear in that room. The following phrase takes connects two rooms with a door, and makes the door accessible from two directions. move the portal to north of the Antechamber and east of the Narrow Ledge; We can set a direction to nothing to make a one-sided door: move the portal to north of the Antechamber and nothing from the Lava Pit; The "preserving routes" option moves the door but does not remove the old connection. At the end of this example, the Sloping Canyon is still accessible from the Echoing Cavern, though not by the door: move the tunnel-drilling door to north of the Echoing Cavern and south of the Sloping Canyon; move the tunnel-drilling door to west of the Echoing Cavern and east of the Pit Room, preserving routes; Section: Finer controls If we want to keep some of the rooms or directions the same and change others, the "move" phrase is overkill. Instead, we can use the "replace" phrase. These examples assume the following set-up: The chute is a door. It is east of the Cargo Bay. To change the direction to exit the Cargo Bay: replace east in the chute with north; If a room and a direction are both nothing (as they are in the chute, a one-sided door), the phrase will still do the right thing: replace nothing in the chute with the Back of Truck; replace nothing in the chute with south; We can use the "on the opposite side" option to replace the room/direction on the opposite of the door from the one specified. This example has exactly the same effect as the previous one: replace the Cargo Bay in the chute with the Back of Truck, on the opposite side; replace east in the chute with south, on the opposite side; The "preserving routes" option works with this phrase too. Section: Searching a door We can get the rooms and directions of a door, provided we already know one: let O be the room matching east in the blast door; let O be the room matching Munitions Depot in the blast door, on the opposite side; let O be the direction matching the Docks in the gangplank; let O be the room matching nothing in the slippery slide; If we don't care what the value is, provided it is not nothing, we can use: if Cargo Bay is matched in the chute, say "This text will appear."; if northwest is matched in the chute, say "This text will not appear."; Section: Removing a door There are two ways to remove a door from play: now the trapdoor is nowhere; remove the trapdoor from play; The second way can take the "preserving routes" option: Instead of attacking the rotten door: remove the rotten door from play, preserving routes; say "[The rotten door] falls to pieces."
Version 1 of Mobile Doors by David Corbett begins here. Chapter 1 - New properties Include (- with mobile false with mobile_door nothing nothing nothing nothing with mobile_door_dir [ loc; loc = location; if (loc == thedark) loc = real_location; if (loc == (self.&mobile_door)-->0) return (self.&mobile_door)-->3; return (self.&mobile_door)-->2; ] with mobile_door_to [ loc; loc = location; if (loc == thedark) loc = real_location; if (loc == (self.&mobile_door)-->0) return (self.&mobile_door)-->1; return (self.&mobile_door)-->0; ] -) when defining a door. Chapter 2 - Mobility Include (- [ MobilizeDoor d set; if (set < 0) return d.mobile; if (set == true && d.mobile == false) { d.mobile = true; if (d provides found_in) { ! two-sided door (d.&mobile_door)-->0 = (d.&found_in)-->0; (d.&mobile_door)-->1 = (d.&found_in)-->1; @push location; location = LocationOf((d.&mobile_door)-->0); (d.&mobile_door)-->2 = d.door_dir(); location = LocationOf((d.&mobile_door)-->1); (d.&mobile_door)-->3 = d.door_dir(); @pull location; } else { ! one-sided door (d.&mobile_door)-->0 = parent(d); (d.&mobile_door)-->1 = d.door_to; (d.&mobile_door)-->2 = d.door_dir; } (d.&door_dir)-->0 = (d.&mobile_door_dir)-->0; (d.&door_to)-->0 = (d.&mobile_door_to)-->0; } ! Once a mobile door, always a mobile door. ]; -). Chapter 3 - Removal from play Section 3.1 - Phrase To remove (D - door) from play, preserving routes: (- RemoveFromPlay({D}, {phrase options}); -). Section 3.2 - Modified AssertMapConnection Include (- Replace AssertMapConnection; -) before "WorldModel.i6t". Include (- [ AssertMapConnection r1 dir r2 in_direction; SignalMapChange(); in_direction = Map_Storage--> ((r1.IK1_Count)*No_Directions + dir.IK3_Count); if ((in_direction == 0) || (in_direction ofclass (+ room +) or (+ door +))) { Map_Storage-->((r1.IK1_Count)*No_Directions + dir.IK3_Count) = r2; return; } RunTimeProblem(RTP_NOEXIT, r1, dir); ]; -). Section 3.3 - Modified RemoveFromPlay Include (- Replace RemoveFromPlay; -) before "WorldModel.i6t". Include (- [ RemoveFromPlay F preserve; if (F == nothing) return RunTimeProblem(RTP_CANTREMOVENOTHING); if (F == player) return RunTimeProblem(RTP_CANTREMOVEPLAYER); if (F ofclass (+ door +)) { MobilizeDoor(F, true); SignalMapChange(); ! The door will keep the values in mobile_door after removal, but SearchDoor relies on this. if (preserve) { if ((F.&mobile_door)-->0 ~= nothing && (F.&mobile_door)-->2) AssertMapConnection((F.&mobile_door)-->0, (F.&mobile_door)-->2, (F.&mobile_door)-->1); if ((F.&mobile_door)-->1 ~= nothing && (F.&mobile_door)-->3) AssertMapConnection((F.&mobile_door)-->1, (F.&mobile_door)-->3, (F.&mobile_door)-->0); } else { if ((F.&mobile_door)-->0 ~= nothing && (F.&mobile_door)-->2) AssertMapConnection((F.&mobile_door)-->0, (F.&mobile_door)-->2, nothing); if ((F.&mobile_door)-->1 ~= nothing && (F.&mobile_door)-->3) AssertMapConnection((F.&mobile_door)-->1, (F.&mobile_door)-->3, nothing); } } if (IndirectlyContains(F, player)) return RunTimeProblem(RTP_CANTBEOFFSTAGE); give F ~worn; DetachPart(F); if (F ofclass K7_backdrop) give F absent; remove F; ]; -). Section 3.4 - Modified MoveFloatingObjects Include (- Replace MoveFloatingObjects; -) before "WorldModel.i6t". Include (- [ MoveFloatingObjects toroom i k l m address flag; if (toroom == nothing) toroom = real_location; if (toroom == nothing) return; objectloop (i) { if (i provides mobile && i.mobile) { if ((toroom == (i.&mobile_door)-->0 && (i.&mobile_door)-->2 ~= nothing) || (toroom == (i.&mobile_door)-->1 && (i.&mobile_door)-->3 ~= nothing)) { if (i notin toroom) move i to toroom; } } else { address = i.&found_in; if (address ~= 0 && i hasnt absent) { if (ZRegion(address-->0) == 2) { m = address-->0; .TestPropositionally; if (m.call(toroom) ~= 0) move i to toroom; else { if (i in toroom) remove i; } } else { k = i.#found_in; for (l=0 : l<k/WORDSIZE : l++) { m = address-->l; if (ZRegion(m) == 2) jump TestPropositionally; if (m == toroom || m in toroom) { if (i notin toroom) move i to toroom; flag = true; } } if (flag == false) { if (i in toroom) remove i; } } if ((i ofclass K4_door) && (parent(i) == nothing)) { move i to ((i.door_to).call()); } } } } ]; -). Chapter 4 - Updating To replace (query - object) in (D - door) with (replacement - object), on the opposite side, and/or preserving routes: (- SearchDoor({D}, {query}, {replacement}, {phrase options}, true); -). Chapter 5 - Querying Section 5.1 - Room query To decide what object is room matching (query - object) in (D - door), on the opposite side: (- SearchDoor({D}, {query}, IK1_First, {phrase options}) -). Section 5.2 - Direction query To decide what object is direction matching (query - object) in (D - door), on the opposite side: (- SearchDoor({D}, {query}, IK3_First, {phrase options}) -). Section 5.2 - Predicate To decide whether (query - object) is matched in (D - door): (- (SearchDoor({D}, {query})) -). Chapter 6 - Searching a door Include (- [ SearchDoor d old new opt modify i j; if (old == nothing && new == nothing) return; RemoveFromPlay(d, opt); for (i = 0: i < 4: i++) { if ((d.&mobile_door)-->i ~= old) continue; if (opt & 1) j = (i | 1) & (~(i & 1)); ! on the opposite side else j = i; if ((new ofclass (+ room +) && (j & 2) == 2) || (new ofclass (+ direction +) && (j & 2) == 0)) { if (old == nothing) continue; j = (j | 2) & (~(j & 2)); ! of the other class (room vs. direction) } if (modify == true) (d.&mobile_door)-->j = new; else return (d.&mobile_door)-->j; } for (i = 0 : i < 2 : i++) if ((d.&mobile_door)-->i ~= nothing && (d.&mobile_door)-->(i + 2) ~= nothing) AssertMapConnection((d.&mobile_door)-->i, (d.&mobile_door)-->(i + 2), d); MoveFloatingObjects(); rfalse; ]; -). Chapter 7 - Moving Section 7.1 - Phrase To move (D - door) to (C1 - object) from/of (R1 - object) and (C2 - direction) from/of (R2 - object), preserving routes: (- MoveDoor({D}, {R1}, {R2}, {C1}, {C2}, {phrase options}); -). Section 7.2 - I6 implementation Include (- [ MoveDoor d room1 room2 dir1 dir2 opt; RemoveFromPlay(d, opt); (d.&mobile_door)-->0 = room1; (d.&mobile_door)-->1 = room2; (d.&mobile_door)-->2 = dir1; (d.&mobile_door)-->3 = dir2; if ((d.&mobile_door)-->0 ~= nothing && (d.&mobile_door)-->2 ~= nothing) AssertMapConnection((d.&mobile_door)-->0, (d.&mobile_door)-->2, d); if ((d.&mobile_door)-->1 ~= nothing && (d.&mobile_door)-->3 ~= nothing) AssertMapConnection((d.&mobile_door)-->1, (d.&mobile_door)-->3, d); MoveFloatingObjects(); ]; -). Mobile Doors ends here.